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DETAILED ACTION 
Continued Examination Under 37 CFR 1.114 

1 . A request for continued examination under 37 CFR 1.114, including the fee set 
forth in 37 CFR 1.17(e), was filed in this application after final rejection. Since this 
application is eligible for continued examination under 37 CFR 1.114, and the fee set 
forth in 37 CFR 1.17(e) has been timely paid, the finality of the previous Office action 
has been withdrawn pursuant to 37 CFR 1.114. Applicant's submission filed on July 12, 
2007 has been entered. 

2. In response to the last Office Action, claims 1, 8, 27 and 28 have been amended. 
Claims 10-26 were previously withdrawn. Claims 1-9 and 27-30 are pending. 

Response to Arguments 

3. Applicant's arguments with respect to claims 1 , 8, 27, and 28 have been 
considered but are moot in view of the new ground(s) of rejection. 
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Claim Rejections - 35 USC § 103 

4. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

5. Claims 1-6 are rejected under 35 U.S.C. 103(a) as being unpatentable over Lum 
(5,696,931) over Hicken (6,092,149) and further in view of Napolitano (6,301,605). 

As per claim 1 , Lum discloses a mass storage system comprising: 
a mass storage device (Fig. 1; storage device 104); a cache memory coupled to the 
mass storage device, the cache memory being organized in data blocks and having a 
first data block (Fig. 1, disk cache 118, where it is understood that a cache is composed 
of multiple data blocks); a microprocessor coupled to the mass storage device and the 
cache memory (Fig. 1, microprocessor 114); and a controller coupled to the 
microprocessor and the cache memory (Fig. 1; controller 106), wherein the controller: 
receives a data request from a host system (column 4, lines 4041); calculates new 
cache counter and pointer values when the first requested data block is not contained 
within the first block of the cache (column 7, lines 15-62); initiates an auto-transfer of the 
requested data that resides in the cache to the host system (column 4, lines 40-46); and 
requests a transfer of the requested data that resides in the mass storage device to the 
host system (column 9, lines 44-55). 
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However, Lum does not explicitly teach calculate new cache counter and pointer 
values when the first requested data block is not contained within the first block of the 
cache as claimed. 

Hicken discloses. calculate new cache counter and pointer values when the first 
requested data block is not contained within the first block of the cache [col. 2, II 54-65] 
to process buffered data and commands to and from a host computer in the event of a 
full cache hit and a partial cache hit (col. 1, II 23-25; col. 2, II 55-60). 

Since the technology for implementing a disk controller which calculates new 
cache counter and pointer values when the first requested data block is not contained 
within the first block of the cache was well known as evidenced by Hicken, an artisan 
would have been motivated to implement this feature in the system of Lum in order to 
process buffered data and commands to and from a host computer in the event of a full 
cache hit and a partial cache hit. Thus, it would have been obvious to one of ordinary 
skill in the art, at the time of invention by Applicant to modify the system of Lum to 
include calculating new cache counter and pointer values when the first requested data 
block is not contained within the first block of the cache because this would have helped 
with processing buffered data and commands to and from a host computer in the event 
of a full cache hit and a partial cache hit (col. 1 , II 23-25; col. 2, II 55-60) as taught by 
Hicken. 

However Lum and Hickem do not explicitly teach requesting a transfer of the 
requested data that resides in the mass storage device directly to the host system. 
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Napolitano discloses requesting a transfer of the requested data that resides in 
the mass storage device directly to the host system [col. 10, II 32-35] so that the data is 
available at the host if and when requested (col. 10, II 34-45). 

Since the technology for implementing a storage system with teach requesting a 
transfer of the requested data that resides in the mass storage device directly to the 
host system was well known as evidenced by Napolitano, an artisan would have been 
motivated to implement this feature in the system of Lum and Hicken so that the data is 
available at the host if and when requested. Thus, it would have been obvious to one of 
ordinary skill in the art at the time of invention by applicant to modify the system of Lum 
and Hickem to include requesting a transfer of the requested data that resides in the 
mass storage device directly to the host system since this would have made the data 
available at the host if and when requested (col. 10, II 34-35) as taught by Napolitano. 

As per claim 2, Lum discloses a controller register including: 
a counter register containing a value for the number of blocks of data in the 
cache memory (column 5, lines 65-67), a start address register identifying the first block 
of data in the cache memory (column 6, lines 14-18); and a pointer register containing 
a pointer to the first block of data in the cache memory (column 8, lines 4-16). 

As per claim 3, Lum discloses the microprocessor transfers the requested data 
that resides in the mass storage device to the host system by way of the cache memory 
(column 9, lines 44-55). 
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As per claim 4, Lum discloses the microprocessor controls the transfer of requested 
data that resides in the mass storage device and the controller controls the transfer of 
requested data that resides in the cache (column 4, lines 41-47; column 9, lines 44-47). 

As per claim 5, Lum discloses the controller includes a general or special purpose 
processor executing program instructions (Fig. 1, microprocessor 114). 

As per claim 6, Lum discloses the transfer of requested data that resides in the mass 
storage device occurs substantially simultaneously with the transfer of data that resides 
in the cache (column 9, lines 1-55; column 10, lines 36-38). 

6. Claims 8, 27-28 and 30 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Lum (5,696,931) over Simionescu (6,141,728) and further in view of 
Napolitano (6,301,605). 

As per claim 8, Lum discloses a method of retrieving data from a mass storage 
system comprising: receiving a data request from a host system, the data request 
including a block address for a first block of the requested data and a number of blocks 
in the request (column 4, lines 40-41; Fig. 1, disk cache 118, where it is understood that 
a cache is composed of multiple data blocks; column 5, lines 65-67); if none of the 
requested data is in a cache memory, initiating a transfer of the requested data from a 
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mass storage device (column 9, lines 44-47); if a portion of the requested data is in the 
cache memory and a portion of the requested data is in the mass storage device, 
transferring the portion of the requested data from the cache memory to the host system 
substantially concurrently with transferring the portion of the requested data from the 
mass storage devices to the host system (column 9, lines 1-55; column 10, lines 36-38); 
if all the requested data is in the cache memory, transferring the requested data from 
the cache memory to the host system (column 4, lines 41-47); wherein the steps of 
transferring the requested data from the cache memory system include calculating a 
starting location in the cache memory for the transfer, based upon the block address 
and the number of blocks in the request received from the host system (column 5, line 
62 -column 6, line 18). 

However, Lum does not explicitly teach transferring a portion of the requested 
data from the cache memory to the host system substantially concurrently with 
transferring a portion of the requested data from the mass storage devices to the host 
as claimed. 

Simionescu discloses transferring a portion of the requested data from the cache 
memory to the host system substantially concurrently with transferring a portion of the 
requested data from the mass storage devices to the host [col. 21 , II 20-26] to quickly 
and efficiently buffer multiple data transfers into the cache buffer (col. 2, II 5-10). 

Since the technology for implementing a disk controller with transferring a portion 
of the requested data from the cache memory to the host system substantially 
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concurrently with transferring a portion of the requested data from the mass storage 
devices to the host was well known as evidenced by Simionescu, an artisan would have 
been motivated to implement this feature in the system of Lum in order to quickly and 
efficiently buffer multiple data transfers into the cache buffer. Thus, it would have been 
obvious to one of ordinary skill in the art, at the time of invention by Applicant, to modify 
the system of Lum to include transferring a portion of the requested data from the cache 
memory to the host system substantially concurrently with transferring a portion of the 
requested data from the mass storage devices to the host because this would have 
quickly and efficiently buffered multiple data transfers into the cache buffer (coi. 2, II 5- 
10) as taught by Simionescu. 

However Lum and Simionescu do not explicitly teach requesting a transfer of the 
requested data that resides in the mass storage device directly to the host system. 

Napolitano discloses requesting a transfer of the requested data that resides in 
the mass storage device directly to the host system [col. 10, II 32-35] so that the data is 
available at the host if and when requested (col. 10, II 34-45). 

Since the technology for implementing a storage system with teach requesting a 
transfer of the requested data that resides in the mass storage device directly to the 
host system was well known as evidenced by Napolitano, an artisan would have been 
motivated to implement this feature in the system of Lum and Simionescu so that the 
data is available at the host if and when requested. Thus, it would have been obvious to 
one of ordinary skill in the art at the time of invention by applicant to modify the system 
of Lum and Simionescu to include requesting a transfer of the requested data that 
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resides in the mass storage device directly to the host system since this would have 
made the data available at the host if and when requested (col. 10, II 34-35) as taught 
by Napolitano. 



As per claim 27, the rationale in the rejection of claim 8 is herein incorporated. 
Lum further discloses a disk memory system, comprising: 

a disk-device for storing data-blocks on disk-storage-media (Fig. 1; storage device 104, 
where it is understood that disk tracks or segments store data blocks); a cache for 
storing data-blocks (Fig. 1, disk cache 118, where it is understood that a cache is 
composed of multiple data blocks); a disk-controller (Fig. 1; controller 106); registers 
within said disk-controller containing a cache-start-address of a first data-block in said 
cache (column 6, lines 14-18), and a cache-block-length that defines a total number of 
data-blocks stored in said cache (column 5, lines 65-67); said disk-controller receiving a 
data-request that contains a request-start-address of a first data-block in said data- 
request, and a request-block-length that defines a total number of data-blocks in said 
data-request (column 4, lines 40-41); a microprocessor operationally interconnecting 
said disk-device, said cache, and said disk-controller (Fig. 1, microprocessor 114); 
logic means in said disk-controller responsive to said cache-start-address as compared 
to said request-start-address, and to said cache-block-length-as compared to said 
request-block-length (column 7, lines 15-62; column 5, line 62 - column 6, line 18); 
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said logic means being operable to determine when no data-blocks corresponding to 
said data-request reside in said cache, and operating in response to such a 
determination to cause said microprocessor to fetch said data-blocks corresponding to 
said data-request from said disk-device (column 9, lines 44-47); said logic means being 
operable to determine when all of the data-blocks corresponding to said data-request 
reside in said cache, and operating in response to such a determination to cause said 
disk-controller to auto-transfer all of said data-blocks corresponding to said data- 
request from said cache without requiring operation of said microprocessor (column 4, 
lines 40-46); and said logic means being operable to determine when a cache-hit- 
portion of data-blocks corresponding to said data-request reside in said cache and a 
cache-miss-portion of said data-blocks corresponding to said data-request do not reside 
in said cache, and operating in response to such a determination to concurrently cause 
said disk-controller to auto-transfer said cache-hit-portion of said data-blocks 
corresponding to said data-request from said cache, and to cause said microprocessor 
to fetch data-blocks corresponding to said cache-miss-portion of said data-request from 
said disk-device (column 9, lines 1-55; column 10, lines 36-38). 

As per claim 28, the rationale in the rejection of claim 8 is herein incorporated. 
Lum further discloses a disk memory system, comprising: 
a relatively slow disk-device for storing data-blocks on disk-storage-media (Fig. 1 ; 
storage device 104, where it is understood that disk tracks or segments store data 
blocks); a relatively fast cache for storing data-blocks (Fig. 1, disk cache 118, where it is 
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understood that a cache is composed of multiple data blocks); a disk-controller (Fig. 1; 
controller 106), and a microprocessor (Fig. 1, microprocessor 114); registers within said 
disk-controller containing a cache-start-address of a first data-block in said cache 
(column 6, lines 14-18), and a cache-block-length that defines a total number of data- 
blocks stored in said cache (column 5, lines 65-67); said disk-controller receiving as 
input a data-request from said host-system; said data request containing a request- 
start-address of a first data-block in said data-request, and a request-block-length that 
defines a total number of data-blocks in said data-request (column 4, lines 40-41); 
a logic circuit in said disk-controller responsive to said cache-start address as 
compared to said request-start-address, and to said cache-block-length as compared to 
said request-block-length (column 9, lines 44-47); said logic circuit being operable to 
determine a cache-miss when no data-blocks corresponding to said data-request reside 
in said cache, and operating in response to a cache-miss to cause said microprocessor 
to fetch said data-blocks corresponding to said data-request from said disk-device 
(column 9, lines 44-47); said logic circuit being operable to determine a total-cache-hit 
when all of the data-blocks corresponding to said data-request reside in said cache, and 
operating in response to a total-cache-hit to cause said disk-controller to auto-transfer 
all of said data-blocks corresponding to said data-request from said cache without 
requiring operation of said microprocessor (column 4, lines 40-46); and said logic circuit 
being operable to determine a partial-cache-hit when a first-portion of data-blocks 
corresponding to said data-request reside in said cache and a second-portion of said 
data-blocks corresponding to said data-request do not reside in said cache, and 
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operating in response to a partial-cache-hit to concurrently cause said disk-controller to 
auto-transfer said first-portion of said data-blocks corresponding to said data-request 
from said cache, and to cause said microprocessor to fetch data-blocks corresponding 
to said second-portion of said data-request from said disk-device (column 9, lines 1-55; 
column 10, lines 36-38). 

As per claim 30, Simionescu discloses the logic means include a processor 
executing programmed instructions [Fig. 1]. 

7. Claim 7 is rejected under 35 U.S.C. 103(a) as being unpatentable over 

Lum et al (US 5,696,931) in view Hicken (6,092,149), Napolitano (6,301,605), and of 
well-known practices in the art. 

Regarding claim 7, Lum discloses the claimed invention as per the rejection of 
claim 1 supra. Lum does not explicitly disclose the mass storage system and the host 
system are integrated into a single unit as required in the claim. However, to make 
integral is generally not given patentable weight. 

Furthermore, integrating memory and logic on a single device is a common and 
well-known practice in the art, to reduce pin count, power and area, and to increase the 
data transfer rate between elements. Therefore, it would have been obvious to one of 
ordinary skill in the art at the time of the invention by applicant to.integrate the mass 
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storage and the host in the system of Lum to reduce pin count, power and area, and to 
increase the data transfer rate between elements based on conventional practices. 

8. Claim 29 is rejected under 35 U.S.C. 103(a) as being unpatentable over 
Lum et al (US 5,696,931) in view Simionescu (6,141,728), Napolitano (6,301,605) 

and of well-known practices in the art. 

Regarding claim 29, Lum discloses the claimed invention as per the rejection of 
claim 28 supra. Lum does not explicitly disclose the mass storage system and the host 
system are integrated into a single unit as required in the claim. However, to make 
integral is generally not given patentable weight. 

Furthermore, integrating memory and logic on a single device is a common and 
well-known practice in the art, to reduce pin count, power and area, and to increase the 
data transfer rate between elements. Therefore, it would have been obvious to one of 
ordinary skill in the art at the time of the invention by applicant to integrate the mass 
storage and the host in the system of Lum to reduce pin count, power and area, and to 
increase the data transfer rate between elements based on conventional practices. 

9. Claim 9 is rejected under 35 U.S.C. 103(a) as being unpatentable over Lum et al 
(US 5,696,931) in view of Simionescu (6,141,728), Napolitano (6,301,605) and Taroda 
et al (US Pub 200110014929) A1). 
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As per claim 9, Lum, Simionescu, and Napolitano disclose the claimed 
invention as per the rejection of claim 8 supra. Lum, Simionescu, and Napolitano do not 
explicitly disclose the data request has a first logical address protocol and the cache 
memory has a second logical address protocol and including the step of translating 
between the first and second address protocols as required in the claim. 

Taroda discloses a disk control device having a block format different from the 
host wherein the first and second formats can be converted (Paragraphs 12-16) to 
realize access compatible with the two different formats. 

Thus, it would have been obvious to one of ordinary skill at the time of the 
invention by applicant, to modify the system of Lum and Simionescu to include 
converting formats between the host and the disk controller in the manner taught by 
Taroda, because it was well known to realize access compatible with the two different 
formats (Paragraph 14) as taught by Taroda. 



Conclusion 

10. When responding to the office action, Applicant is advised to clearly point out the 
patentable novelty that he or she thinks the claims present in view of the state of the art 
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disclosed by references cited or the objections made. He or she must also show how 
the amendments avoid such references or objections. See 37 C.F.R. 1.111(c). 

1 1 . When responding to the Office action, Applicant is advised to clearly point out 
where support, with reference to page, line numbers, and figures, is found for any 
amendment made to the claims. 

12. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Mardochee Chery whose telephone number is (571) 
272-4246. The examiner can normally be reached on 8:30A-5:00P. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Hyung Sough can be reached on (571) 272-6799. The fax phone number 
for the organization where this application or proceeding is assigned is 571-273-8300. 
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Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 

August 18, 2007 





Mardochee Chery 

Examiner 

AU:2188 



